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DETAILED ACTION 

1. This is in response to the amendment filed on August 23 rd , 2007. Claims 1, 9, 13, 18, 24, 
25 and 31 have been amended, Claims 1-31 are pending and have been considered below. 

Information Disclosure Statement 

2. The information disclosure statement (IDS) submitted on 05/30/07 is in compliance with 
the provisions of 37 CFR 1.97. Accordingly, the information disclosure statement is being 
considered by the examiner. 

Specification 

3. The amendments filed on August 23 rd , 2007 have been considered and is effective at 
overcoming the previous objections to the specification. Therefore, the previous objections to 
the specification have been withdrawn. 

Claim Objections 

4. The amendments filed on August 23 rd , 2007 have been considered and is effective at 
overcoming the previous claim objections. Therefore, the previous claim objections have been 
withdrawn. 
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Claim Rejections -35 USC §112 

5. The amendments filed on August 3 rd , 2007 have been considered and is effective at 
overcoming the previous 35 USC § 1 12 2 nd paragraph rejections. Therefore, the previous claim 
rejections have been withdrawn. 

Claim Rejections - 35 USC § 103 

6. The text of those sections of Title 35, U.S. Code not included in this action can be found 
in a prior Office action. 

7. Claims 1-31 are rejected under 35 U.S.C. 103(a) as being unpatentable over Yup et 
aL (2002/0191784) in view of DhiretaL (2005/0084076). 

Claim 1: Yup et al. discloses an apparatus for performing cryptographic operations, comprising: 

a. a cryptographic instruction, received by a computing device as part of an instruction 
flow executing on said computing device, wherein said cryptographic instruction prescribes one 
of the cryptographic operations, and wherein said cryptographic instruction prescribes one of a 
plurality of data block s\zzs(AES block cipher can be performed on 128-bit, 192-bit or 256-bit 
blocks) [page 4, paragraph 0045]; 

b. and execution logic, operatively coupled to said cryptographic instruction, configured 
to execute said one of the cryptographic operations, said execution logic comprising a block size 
controllers^ expansion block), configured to employ said one of a plurality of data block sizes 
during execution of said one of the cryptographic operations [page 3, paragraph 0028]. 

However, Yup et al. does not explicitly disclose performing these instructions on a 
microprocessor based platform. 
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Nonetheless, Dhir et al. discloses a similar apparatus and further discloses performing 
cryptographic instructions^, program instructions) to implement the Advanced Encryption 
Standard algorithm on a microprocessor based platform(7e. FPGA) [page 5, paragraph 0051]. 

Therefore, it would have been obvious to one of ordinary skill in the art at the time of 
invention to perform these instructions on a microprocessor based platform or any other platform 
in order to meet particular design requirements. 

Claim 2: Yup et al. and Dhir et al. disclose an apparatus as in claim 1 above and Yup et al. 
further discloses that said one of the cryptographic operations further comprises an encryption 
operation, said encryption operation comprising encryption of a plurality of plaintext 
blocks(plurality of channels with input means) to generate a corresponding plurality of ciphertext 
blocks (plurality of channels with output means) [page 2, paragraph 0017], 
Claim 3: Yup et al. and Dhir et al. disclose an apparatus as in claim 1 above and Yup et al. 
further discloses that said one of the cryptographic operations further comprises a decryption 
operation, said decryption operation comprising decryption of a plurality of ciphertext 
blocks(plurality of channels with input means) to generate a corresponding plurality of plaintext 
blocks(plurality of channels with output means) [page 2, paragraph 0017]. 
Claims 4-6: Yup et al. and Dhir et al. disclose an apparatus as in claim 1 above and Yup et al. 
further discloses that said one of a plurality of data block sizes comprises 128 bits, 192 bits or 
256 bits [page 4, paragraph 0045]. 

Claim 7: Yup et al. and Dhir et al. disclose an apparatus as in claim 1 above and Yup et al. 
further discloses that said one of the cryptographic operations is executed according to the 
Advanced Encryption Standard (AES) algorithm [page 2, paragraph 0016]. 
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Claim 8: Yup et al. and Dhir et al. disclose an apparatus as in claim 1 above and Yup et al. 
further discloses that said data block controllers^ expansion block) is configured to interpret a 
data block size fic\d(nb = block size) within a control word which is referenced by said 
cryptographic instruction (the key expansion block generates a single round key by performing a 
single key expansion operation for each round of the AES block cipher) [page 3, paragraph 
0028]. 

Claims 10-12: Yup et al, and Dhir et al. disclose an apparatus as in claim 1 above and Yup et al. 
further discloses that said cryptographic instruction implicitly references a plurality of registers 
within said computing device, which include a first register, wherein contents of said first 
register (plaintext storage registers) comprise a first pointer to a first memory address, said first 
memory address specifying a first location in memory for access of a plurality of input text 
blocks upon which said one of the cryptographic operations is to be accomplished, said plurality 
of input text blocks are sized according to said one of a plurality of data block sizes [page 4, 
paragraph 0043]; and a second register (cipher block output storage register), wherein contents of 
said second register comprise a second pointer to a second memory address, said second memory 
address specifying a second location in said memory for storage of a corresponding plurality of 
output text blocks, said corresponding plurality of output text blocks being generated as a result 
of accomplishing said one of the cryptographic operations upon a plurality' of input text blocks, 
wherein said plurality of input and output text blocks are sized according to said one of a 
plurality of data block sizes [page 4, paragraphs 0043-0044]. 

Claim 14: Yup et al. and Dhir et al. disclose an apparatus as in claim 10 above and Yup et al. 
further discloses that said plurality of registers comprises a fourth register (cipher key storage 
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register), wherein contents of said fourth register comprise a third pointer to a third memory 
address, said third memory address specifying a third location in memory for access of 
cryptographic key data for use in accomplishing said one of the cryptographic operations [page 
3, paragraph 0028]. 

Claim 15: Yup et al. and Dhir et al. disclose an apparatus as in claim 10 above and Yup et al. 
further discloses that said plurality of registers comprises a fifth register, wherein contents of 
said fifth register comprise a fourth pointer to a fourth memory address, said fourth memory 
address specifying a fourth location in memory, said fourth location comprising said 
initialization vector location, contents of said initialization vector location comprising an 
initialization vector or initialization vector equivalent for use in accomplishing said one of the 
cryptographic operations [page 3, paragraph 0027]. The examiner notes that Yup et al. discloses 
operating the apparatus in CBC mode, which implies the use of initialization vectors. Thus, it is 
inherent for the initialization vectors to be stored in memory. 

Claim 16: Yup et al. and Dhir et al. disclose an apparatus as in claim 8 above and Yup et al. 
further discloses that said plurality of registers comprises a sixth register, wherein contents of 
said sixth register comprise a fifth pointer to a fifth memory address, said fifth memory address 
specifying a fifth location in memory for access of a control word for use in accomplishing said 
one of the cryptographic operations, wherein said control word prescribes cryptographic 
parameters for said one of the cryptographic operations, and wherein said control word 
comprises a data block size fields = block size), configured to specify said one of a plurality of 
data block sizes to be employed during execution of said one of the cryptographic operations 
key expansion block generates a single round key by performing a single key expansion 
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operation for each round of the AES block cipher) [page 3, paragraph 0028]. The examiner 
notes that it is inherent for the control word to be stored in memory because the key expansion 
block uses it for generating a round key. 

Claim 17: Yup et al. and Dhir et al. disclose an apparatus as in claim 1 above and Yup et al. 
further discloses that said execution logic comprises a cryptography unit, configured execute a 
plurality of cryptographic rounds on each of a plurality of input text blocks to generate a 
corresponding each of a plurality of output text blocks, wherein said one of a plurality of data 
block sizes is prescribed by a control word that is provided to said block size controller within 
said cryptography unit [page 1, paragraph 0004]. 

Claim 18: Yup et al. discloses an apparatus for performing cryptographic operations, 
comprising: 

a. a cryptography unit within a device, configured to execute one of the cryptographic 
operations responsive to receipt of a cryptographic instruction within an instruction flow that 
prescribes said one of the cryptographic operations, wherein said cryptographic instruction also 
prescribes a block size to be employed when executing said one of the cryptographic 
operations'^ block cipher can be performed on 128-bit, 192-bit or 256-bit blocks) [page 4, 
paragraph 0045]; 

b. and block size \og\c(key expansion block), operatively coupled within said 
cryptography unit, configured to direct said device to employ said block size when performing 
said one of the cryptographic operations [page 3, paragraph 0028]. 

However, Yup et al. does not explicitly disclose performing these instructions on a 
microprocessor based platform. 
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Nonetheless, Dhir et al. discloses a similar apparatus and further discloses performing 
cryptographic instructions (ie. program instructions) to implement the Advanced Encryption 
Standard algorithm on a microprocessor based platform(7e. FPGA) [page 5, paragraph 0051]. 

Therefore, it would have been obvious to one of ordinary skill in the art at the time of 
invention to perform these instructions on a microprocessor based platform or any other platform 
in order to meet particular design requirements. 

Claims 19-21: Yup et al. and Dhir et al disclose an apparatus as in claim 18 above and Yup et 
ah further discloses that said block size comprises 128-bits, 192-bits or 256-bits [page 4, 
paragraph 0045]. 

Claim 22: Yup et al. and Dhir et al. disclose an apparatus as in claim 1 8 above and Yup et al. 
further discloses that said one of the cryptographic operations is executed according to the 
Advanced Encryption Standard (AES) algorithm [page 2, paragraph 0016]. 
Claim 23: Yup et al. and Dhir et al. disclose an apparatus as in claim 18 above and Yup et al. 
further discloses that said block size \ogic(key expansion block) is configured to interpret a data 
block size f\dd(nb = block size) within a control word which is referenced by said cryptographic 
instruction [page 3, paragraph 0028]. 

Claim 25: Yup et al. discloses a method for performing cryptographic operations in a device, the 
method comprising: 

a. receiving a cryptographic instruction that prescribes employment of particular block 
size during execution of one of a plurality of cryptographic operations block cipher can be 
performed on 128-bit, 192-bit or 256-bit blocks) [page 4, paragraph 0045]; 
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b. and employing the data block size(key expansion block uses "nb the block size, to 
generate a round key) when executing the one of the cryptographic operations [page 3, 
paragraphs 0028-0035]. 

However, Yup et al. does not explicitly disclose performing these instructions on a 
microprocessor based platform. 

Nonetheless, Dhir et al. discloses a similar method and further discloses performing 
cryptographic instructionsf/e. program instructions) to implement the Advanced Encryption 
Standard algorithm on a microprocessor based platform(7e. FPGA) [page 5, paragraph 0051]. 

Therefore, it would have been obvious to one of ordinary skill in the art at the time of 
invention to perform these instructions on a microprocessor based platform or any other platform 
in order to meet particular design requirements. 

Claim 26: Yup et al. and Dhir et al. disclose a method as in claim 25 above and Yup et al. 
further discloses that said receiving comprises via a fieldfhi = block size) within a control word 
that is referenced by the cryptographic instruction, specifying the particular block size [page 3, 
paragraph 0028]. 

Claims 27-29: Yup et al. and Dhir et al. disclose a method as in claim 26 above and Yup et al. 
further discloses that said specifying comprises prescribing 128 bits, 192 bits or 256 bits as the 
particular block size [page 4, paragraph 0045]. 

Claim 30: Yup et al. and Dhir et al. disclose a method as in claim 25 above and Yup et al. 
further discloses that said employing comprises executing the one of the cryptographic 
operations according to the Advanced Encryption Standard (AES) algorithm [page 2, paragraph 
0016]. 
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Claims 9, 24 and 31: Yup et al. and Dhir et al. disclose a method as in claims 1, 18 and 25 
above, but neither explicitly disclose that said receiving comprises prescribing the cryptographic 
instruction according to the x86 instruction format. However, it would have been obvious to one 
of ordinary skill in the art at the time of invention to create the instructions in x86 format or any 
other format. One would have been motivated to do so in order to conform to the type of 
platform selected for implementation of the encryption/decryption device. 
Claim 13: Yup et al. and Dhir et al. disclose an apparatus as in claim 10 above, but neither 
explicitly discloses that said plurality of registers comprises a third register, wherein contents of 
said third register indicate a number of blocks (channels) within a plurality of input text 
blocks(plurality of channels), wherein said plurality of input text blocks are sized according to 
said one of a plurality of data block sizes [page 2, paragraph 0016]. However, it would have 
been obvious to one of ordinary skill in the art at the time of invention to store the number of 
blocks being encrypted or decrypted. One would have been motivated to do so in order 
recognize when the entire encryption or decryption process is complete. 

Response to Arguments 
8. Applicant's arguments filed on August 23 rd , 2007 have been fully considered but they are 
not persuasive. 

Regarding Claim 1: The Applicant argues that Yup et al. does not disclose cryptographic 
instructions. However, the Examiner respectfully disagrees and submits that while the exact 
term "cryptographic instructions" is not disclosed, Yup et al. does in fact teach cryptographic 
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instructions^, finite state machine controllers which controls the operation of the remaining 
portions of the circuit) [page 3, paragraph 0025]. 

Furthermore, the Applicant argues that Yup et al. does not disclose cryptographic 
instructions received by a microprocessor. However, the Examiner submits that this is moot in 
view of the new ground of rejection. 

Additionally, the Applicant argues that Yup et al. does not disclose execution logic 
coupled to a cryptographic instruction, configured to prescribe a plurality of data block sizes. 
However, the Examiner respectfully disagrees and submits that Yup et al. does in fact disclose 
these features(7e. finite state machine controllers which controls the operation of the remaining 
portions of the circuit, such as the data blocks of which can support block lengths of 128, 192 
and 256 bits) [page 3, paragraphs 0026 & 0028 & 0039]. 

Regarding Claim 18: The Applicant's remarks regarding this claim have been discussed in 
Claim 1 above. 

Regarding Claim 25: The Applicant's remarks regarding this claim have been discussed in 
Claims 1 and 1 8 above. 

Conclusion 

9. Applicant's amendment necessitated the new ground(s) of rejection presented in this 
Office action. Accordingly, THIS ACTION IS MADE FINAL. See MPEP § 706.07(a). 
Applicant is reminded of the extension of time policy as set forth in 37 CFR 1.136(a). 

A shortened statutory period for reply to this final action is set to expire THREE 
MONTHS from the mailing date of this action. In the event a first reply is filed within TWO 
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MONTHS of the mailing date of this final action and the advisory action is not mailed until after 
the end of the THREE-MONTH shortened statutory period, then the shortened statutory period 
will expire on the date the advisory action is mailed, and any extension fee pursuant to 37 



however, will the statutory period for reply expire later than SIX MONTHS from the date of this 
final action. 

Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Edward Zee whose telephone number is (571) 270-1686. The 
examiner can normally be reached on Monday through Thursday 9:00AM-5:00PM EST. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Kim Y. Vu can be reached on (571) 272-3859. The fax phone number for the . 
organization where this application or proceeding is assigned is 571-273-8300. 

Information regarding the status of an application may be obtained from the Patent 
Application Information Retrieval (PAIR) system. Status information for published applications 
may be obtained from either Private PAIR or Public PAIR. Status information for unpublished 
applications is available through Private PAIR only. For more information about the PAIR 
system, see http://pair-direct.uspto.gov. Should you have questions on access to the Private PAIR 
system, contact the Electronic Business Center (EBC) at 866-217-9197 (toll-free). If you would 
like assistance from a USPTO Customer Service Representative or access to the automated 
information system, call 800-786-9199 (IN USA OR CANADA) or 571-272-10$. 



CFR 1 .136(a) will be calculated from the mailing date of the advisory action. In no event, 
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